import axios from "axios";
import { useMainStore } from '../../stores/main'

const mainStore = useMainStore()

const request = axios.create({
  baseURL: 'http://123.207.32.32:1888/api',
  timeout: 1000,
  headers: { 'X-Custom-Header': 'foobar' }
});

// 添加请求拦截器
request.interceptors.request.use(function (config) {
  // 在发送请求之前加载动画
  mainStore.isLoading = true
  return config;
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error);
});

// 添加响应拦截器
request.interceptors.response.use(function (response) {
  // 2xx 范围内的状态码都会触发该函数。
  // 拿到响应数据后隐藏加载
  mainStore.isLoading = false
  return response.data
}, function (error) {
  // 超出 2xx 范围的状态码都会触发该函数。
  // 对响应错误做点什么
  mainStore.isLoading = false
  return Promise.reject(error);
});

export default request